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METHOD AND APPARATUS FOR RETRIEVING DATA 

VI The invention relates to a method of retrieving data 
requested by a host from a first memory divided into allocation 
5 units. 

| [0002] The invention further relates to an apparatus for 
retrieving data requested by a host from a first memory, comprising 
means for receiving data from the first memory, the first memory 
being divided into allocation units; a second memory; and a central 
10 processing unit. 

| 10003.1 The invention also relates to a system for reproducing 
audio-visual information. 

15 C00041 Such a method, apparatus and system are known from U\,S.,,_ 

2001/0021983 — . ■ _J o U.S. Patent 6,725,395 . Th i s deevmwb 

patent p ropo s e s a method of relocating defective sectors on a 
harddisk platter to sectors in a spare area on the platter, and an 
2 0 apparatus for performing this method. According to the method 
| presented in said i3atenfe - -a^plicatio n this patent , the spare areas 
are located outside the data area, either on the outside or inside 
of the disk platter. 



PHNL020988-SS-RED-062507.doc 1 



PHNL 020988 

| When retrieving data from a group of sectors on the 

harddisk platter, in which group certain sectors are defective and 
therefore relocated to sectors in a spare area, the reading head 
has to switch from an area on the disk platter where the group of 
5 sectors is located to either one of the spare areas. Although 3 1 i 
eafe<5afe--^gpM-eafe4eathe paten t proposes embodiments for reducing the 
performance penalty incurred by switching of the head, there will 
always be a performance penalty when retrieving data from said 
group of sectors. This is because the reading head will always have 

10 to make a switch (or "sweep") from the normal data area to the 
sectors in the spare area. 
I [0006] This is a disadvantage of the prior art. Harddisk drive 
systems are more and more used for audio-visual applications, which 
require optimal real-time performance and bandwidth of such 

15 systems. Especially when multiple streams of audio-visual 

information are streamed from the harddisk drive system - or any 
other kind of memory device - performance penalties that occur 
during streaming may cause buffer underflow. When retrieving a 
stream of audio-visual information for playback, this may result in 

20 J k4-ek tf&s-lri raps in the presentation of the stream on screen. This 
not only goes for performance penalties caused by out-of-bound 
relocation of defective sectors, but also for so-called "soft 
defects", sectors of which data has to be read multiple times 
before obtaining the correct data. 
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=00073 Furthermore, it is known from practice that files, either 
data files or streams of audio-visual information, may be stored in 
fragments on the harddisk platter. Switching from one fragment to 
another may incur a performance penalty as well, the reading head 
5 has to switch from one area on the harddisk platter to another. 
During this sweep, no data is read. 

SUMMARY OF TH f \ 
.1.00082. It is an object of the invention to further reduce the 

10 performance penalties of memories during data retrieval. 

| [00 09] This object is achieved by the method according to the 
invention and is characterized in that it comprises the steps of: 
determining in which allocation units the requested data is stored; 
searching a list of references to allocation units to determine 

15 whether the list comprises a reference to at least one of the 

allocation units determined in the previous step; when a reference 
to at least one allocation unit determined in the first step is 
comprised in the list, storing a first part of the data stored in 
the at least one allocation unit in a second memory; and retrieving 

2 0 the requested data, wherein the first part of the requested data is 
retrieved from the second memory and a second part of the requested 
data is retrieved from the first memory, the second part of the 
requested data being complementary to the first part of the 
requested data. 
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| (AH)iOJ By caching certain parts of the requested data prior to 
retrieval of the full amount of data, problems inherent in 
retrieval of certain parts of the requested data will not occur 
during retrieval of the full amount of data. One could think of 
5 damage done to a disk platter of a harddisk drive, making it 

difficult to retrieve certain data. When all the requested data is 
| retrieved in a sequence, e.g..,.. in a streaming mode in case of a 
stream of audio-visual data, and problems occur, the real-time 
performance of a system using the method according to the prior art 

10 may be jeopardized. For example, when a couple of re-read attempts 
are made during retrieval of data, a buf f er-underrun may occur, 
resulting in a black screen for a user. This kind of problem may be 
prevented when using the method according to the invention, when 
building the list from references to allocation units in which data 

15 retrieval are known to cause problems like performance penalties. 
| [0011] In an embodiment of the invention, the first memory has a 
nominal data retrieval rate and the list is built up by using a 
method comprising the steps of: monitoring an average retrieval 
rate with which data is retrieved from the first memory; 

2 0 determining whether the average retrieval rate drops below the 

nominal data retrieval rate; when the average retrieval rate drops 
below the nominal data retrieval rate, determining a part of the 
data of which retrieval causes the drop of the average retrieval 
rate; adding to the list a reference to the allocation units in 



PHNL020988-SS-RED-062507.doc 3 



PHNL 020988 

which data is stored of which the retrieval causes the drop of the 

average retrieval rate. 
| [0012] It is advantageous to let the list of references to 

allocation units be set up by an apparatus using the method 
5 according to the invention itself. In this way, the method 

according to this embodiment may be carried out as a background 

task on the apparatus . 
| [0013] Furthermore, by building the list of references to 

allocation units by the method according to this invention, the 
10 list may be updated. In this way, the method according to the 

invention also deals with problem allocation units that grow during 

use of the first memory. 
| .10014.1. In a further embodiment of the invention, the data is a 

stream of audio-visual data and the file is retrieved in a sequence 
15 dictated by the host. 

| [0015] As already explained, the use of the method according to 

the invention is advantageous when the requested data is a stream, 

retrieved in sequence. Playback of this stream may be controlled by 

the host, by trick-play commands or just by a play command. 
20 | [0016] The apparatus according to the invention is characterized 

in that the central processing unit is conceived to: determine in 

which allocation units the requested data is stored; search a list 

of references to allocation units to determine whether the list 

comprises a reference to at least one of the allocation units in 
25 which the requested data is stored; when at least one allocation 
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unit in which the requested data is stored is comprised in the 
list, store the data stored in the at least one allocation unit in 
a second memory; and retrieve the requested data, wherein a first 
part of the requested data stored in the second memory is retrieved 
5 from the second memory and a second part of the requested data is 
retrieved from the first memory, the second part of the requested 
data is complementary to the first part of the requested data. 
Jil9AZI The system according to the invention comprises the 
apparatus as de fined i i i ~<~ 1 a im 6 de s c r ibed ... above and the first 
10 memory. 

l.Q.Oj-Q.1 Embodiments of the invention will now be presented by 
means of Figures, in which: 
15 | [0019] Figure 1 shows an embodiment of the system according to 
the invention; 

| [0020] Figure 2 shows a disk platter with defective sectors 

relocated to a spare area; 
| [0021] Figure 3 is a flow-chart representing an embodiment of 
2 0 the method according to the invention; 

[0022] Figure 4 shows a further embodiment of the system 

according to the invention;— e&d 

[ 1.0.2.3] Figure 5 shows a disk platter with a file stored in 
fragment s.x and 
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... a . . i or i en of 



5 [0025] Figure 1 shows an apparatus 100 as an embodiment of the 
apparatus according to the invention. The apparatus 100 comprises a 
central processing unit 101, a harddisk drive system 102, a cache 
memory 103 and a video processor 104. In this embodiment, the 
apparatus is adapted to store audio-visual data. To present this 
10 audio-visual data, the apparatus may be connected to a TV-set 120. 

| [ 0026] In a further embodiment of the apparatus according to the 
invention, the harddisk drive system 102 is replaced by a disc 

| drive conceived to receive an optical or magneto-optical disc^ like 
DVD. 

15 | [0027] In the retrieval of audio-visual data, delivery of data 
in time is more important than delivery of faultless data. This is 
because a little noise in a film presented on the TV-set 120 will.,,, 
in most cases^ be less annoying than a blackout of several seconds 
because the harddisk drive system 102 is performing several retries 

2 0 to properly retrieve data that may be faulty anyway. Furthermore, 
data should be delivered constantly and as fast as possible to the 
| video processor 104 to prevent any h4^kr~xm ^h ice up s in the 

presentation of the film. 
| [0028] In use over time , the quality of the disk platter in the 

25 harddisk drive system 102 degrades. This means that certain sectors 
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- the smallest allocation unit on the disk - may become permanently 
defective during use of the harddisk drive system 102. It is known 
in the art that data meant to be stored in such a defective sector 
is relocated to a spare sector. 
5 | [0029] This is shown in Figure 2. Figure 2 shows a disk platter 
200 with a spare area 210 and a read/write head 205 on an arm 207. 
The disk platter 200 is a part of the harddisk drive system 102. On 
| the fea^edjre-kdisk platter— 200, a stream of audio-visual data is 
stored in area 220. Area 220 comprises multiple sectors. Area 220 

10 also comprises a defective sector 225. The defective sector - - 

has been re-assigned to spare sector 215 :: the ... spa r e... a r ea....2.!0 . 

This re-assignment is administered in a memory (not shown) in the 
harddisk drive system 102. To the outside world, data is still 
| stored in the defective sector 225-r™_L_but physically, this data is 

15 located in the spare sector 215. 

| [0030] When the stream of audio-visual data stored in the area 
220 is retrieved from the disk platter 200, retrieval starts at the 
location indicated by a first arrow 230. A first part of the stream 
of audio-visual data between the first arrow 23 0 and the second 

20 arrow 240 can be retrieved easily, because the data is not 

fragmented. This means that the data can be retrieved in one 
rotation of the disk platter 200. The disk platter rotates in the 
direction indicated by a third arrow 250. 
| [0031] However, when the head reaches the defective area 22 5 to 

2 5 retrieve data that is logically stored there, the arm 2 07 has to 
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| move to the • N - > • N , ontt of the disk platter 200 so the head 205 

is able to retrieve data from spare area 215. When the data has 
been retrieved from the spare sector 215, the arm 207 has to move 
back to the outside of the disk platter 200 to position the head 
5 205 to a location indicated by a fourth arrow 260 to retrieve the 
last part of the stream of audio-visual data. 
| [0032] The movement of the arm 207 while retrieving the stream 
of audio-visual data incurs a considerable performance penalty with 
respect to retrieval speed, because no data can be retrieved while 
10 moving the arm 2 07. 

| [0033 ] The performance penalty shows itself as an increased 
access time and/or an average data retrieval rate that is lower 
than the nominal data retrieval rate of the harddisk. 
[0034] This kind of performance degradation may produce h- : k - 
15 i--ip£*£] u s in the retrieval of the stream, causing ^ t > , 

in presentation because of buffer underflow, as already explained. 
The invention proposes a method of reducing this speed penalty and 
| preventing the M--e-k----i-i : pe h 1 c c u p s . 7An embodiment of the method 
according to the invention will be discussed with reference to 
2 0 Figure 1, Figure 2 and Figure 3. 

035] In the embodiment of the invention presented, the 
microprocessor 101 retrieves a list , defective sectors from 

the harddisk drive system 102 . When a file - like a stream of 
audio-visual data - is requested for presentation on the TV-set 
25 120, the central processing unit 101 will command the harddisk 
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drive system 102 to retrieve the file from the disk platter 200. 
This is a starting step 3 02 in a process depicted by a flowchart 
300. In a subsequent process step 304, the central processing unit 
101 determines the area 220 where the file is located on the disk 
5 | platter 200. In a process step 306, the list w-i-i=h--of defective 

sectors is checked to see whether the area 220 where the file is to 
be retrieved eemprises contains defective sectors 225. In a 
decision step 3 08.,.. it is determined whether this is actually the 
case . 

10 | |0036] When the area 220 c ompr i aes c on tains ...de f ec t i ve sectors 
225, the data in the relocated sector 215 is retrieved and stored 
in the cache memory 103 in a process step 320. Following the 
| process step 320, the file is retrieved from the__area___22.Q_ 
harddisk drive system 102, until data to be retrieved is located in 

15 the spare sector 215. As explained before, the data is logically 
stored in the defective sector 225 and physically stored in the 
spare sector 215. When data to be retrieved is located in the spare 
sector 215, the data retrieved previously from the spare sector 215 
is retrieved from the cache memory 103 in a process step 324. 

20 Subsequently, in a decision step 326, it is checked whether the 
file has been fully retrieved. When this is not the case, the 
process depicted by the flowchart 300 is continued in the process 
step 322 in which the last part of the file is retrieved. When, in 
the decision step 326, it is detected that the full file has been 

25 retrieved, the process is stopped in a terminator 312. 
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| v O'V"3 Since.,,, in the process step 324.,., the data stored in the 
relocated sector is retrieved from the cache memory 103, the arm 
2 07 does not have to move to the spare area 210 and the head 2 05 
does not have to be positioned to the spare sector 215. This yields 
5 a considerable gain in data retrieval speed of the harddisk drive 
system 102 as well as of the total apparatus 100. 

[0038] When, in the decision step 3 08, it is detected that the 
area where the file is stored does not ea?se^^e-- c o n tai.n...any 
defective sectors, the full file is retrieved at once from the 

10 harddisk drive system 102. When the file has been fully retrieved, 
the process is stopped in the terminator 312. 
| [0039] For proper execution of the method described by means of 
the flowchart 3 00, it should be known which sectors are relocated 
or which sectors incur performance penalties in general . 

15 | [0040] It is possible to measure the whole drive, but this is 
time-consuming. However, this could be done over a prolonged 
period, preferably when the apparatus conceived to execute the 
method depicted in Figure 3 is in an idle mode. In this embodiment 
of the invention is si - - gure 3, the full drive is scanned 

2 0 and the average data retrieval rate is measured . In particular, the 

A.l\ step 302 wl - v 
. ilc is 

When . the 

average retrieval rate drops below the nominal retrieval rate of 
2 5 | the harddisk drive as specified by the manufacturer , at... step... 603. 
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this is registered and the address of the sector where data is 
stored of which the retrieval causes the drop of the average 
retrieval rate is stored in a list istep 610} . In step 612, wh: 



M sj?ajinij;ig....i.s...cp^ 

to teg 60.4... If the..whgle....di sk^ t;he....pr Gce3K...ends 

- P 616- 

i.00411 A second solution would be to monitor all requests and 
flag any command that takes longer than expected. Suspect areas 
comprising data of which the reading and/or writing takes longer 
than expected could then be further examined, reducing the need to 
scan the whole disk. 

' 0042] The optimal solution is to get the information from the 
harddisk drive system itself. Within the HDD, information on 
relocated sectors is available, but the only problem is how to 
extract it. For future harddisk systems, this might be possible. 

[0043 1 Figure 4 shows an apparatus 400 as a further embodiment 

of the apparatus according to the invention. The apparatus 400 
comprises a central processing unit 401, a harddisk drive system 
402 and a video processor 404. The apparatus 400 is conceived to 
retrieve a stream of audio-visual data from the harddisk drive 
system 402 and process it with the video processor 404. The video 
processor 440 converts the data received from the harddisk drive 
system 402 into a signal presentable on a TV-set 420. 
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| (004 4 J The harddisk drive system 402 comprises a cache memory 
403 . When the harddisk drive system 402 is requested to send a file 
- in this embodiment a stream of audio-visual information - to the 
video processor 404, the harddisk drive system 402 checks whether 
5 the area on a disk platter of the harddisk drive system 402, where 
| the requested file is stored, e omprises contains defective and 
therefore relocated sectors. The defective sectors are relocated to 
spare sectors in a spare area on the disk platter. When the area 
| where the requested file is stored eampri ge e— contains. .. relocated 
10 sectors, the information in the spare sectors is read prior to the 
retrieval of the full file si yi ed in the n<i rug;;; : < 40 ]. . 

oj When, during the retrieval of the file, data from the 
relocated sectors should be retrieved, this data is not retrieved 
from the corresponding spare sectors but from the cache memory 403 . 
15 | [0045] In this embodiment of the invention, the harddisk drive 
system 402 should know where a full file is stored on the disk 
platter. This means that the harddisk drive system 402 needs 
knowledge of the file system of the apparatus 400. 
| [0047] In the embodiments described, data in spare areas is 
2 0 cached. However, in further embodiments, also data of which reading 
takes more time to read for any other reason might be cached. An 
example of this is presented in Figure 5. Figure 5 shows a disk 
platter 500, on which a stream of audio-visual data is stored in 
fragments, and an arm 502 with a read/write head 504. Fragmented 
25 storage may occur when streams are merged or when only little free 
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space is available on the disk platter 500. The stream of audio- 
visual data is stored in a first area 510, a second area 520 and a 
third area 53 0 . 

| [0048] Streaming of the data would necessitate the arm 502 with 
5 read/write head 504 to skip from the location shown by a first 

arrow 512 to the second area 520 so as to retrieve data. When data 
from the second area 52 0 has been retrieved, the arm and read/write 
head 504 has to skip again to the location indicated by the first 
arrow 512 so as to retrieve data from the first area 510 again. 

10 This will continue until the read/write 504 head reaches a location 
indicated by a second arrow 514. When this location is reached, the 
arm 502 with the read/write head 504 has to skip to the third area 
530. When the data from the third area 530 has been retrieved, the 
arm 502 has to skip back to the location indicated by the second 

15 arrow 514 to retrieve the last data of the stream from the first 
area 510. 

| ,[0049] The skipping of the arm 502 and the read/write head 504 
consumes a considerable amount of time. When, prior to the 
retrieval of the stream of audio-visual information, the data 
2 0 stored in the second area 52 0 and the third area 53 0 is cached, 
retrieval of the stream requested can be done faster than in the 
conventional way. 
| [0050] In a further embodiment of the invention, only data 
stored in the first part of the second area 52 0 and the data in the 
25 first part of the third area 530 is cached prior to retrieval of 
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the full stream of audio-visual data. In this way, the gap in 
information retrieval by the harddisk drive system caused by 
switching of the arm 502 is filled by retrieving data from the 
cache memory. This reduces the need for memory space in the cache 
5 as compared to the previous embodiment. 

| [00513 Also..,., other performance penalties.,, like soft defects..,., may 
be considered for caching prior to streaming a file. Soft defects 
occur at locations where the quality of the disk platter is 
degrading, but where data can still be read after a few retries. In 

10 this way, soft defects cause performance penalties as well. 
| [005 2] Of course, retrieval and caching of spare sectors 
consumes time, just as sweeping of an arm with a read/write head 
during retrieval of the full stream. However, current disk platters 
have a fairly good quality and they do not degrade very fast, and 

15 only few sectors have to be relocated to spare sectors in a spare 
area. Therefore, it will only take a few hundred milliseconds to 
cache data that is stored in spare sectors, at start-up. Most users 
| prefer some delay at start-up over hiek-up a h iccup s during display 
of the audio-visual data. 

2 0 | [0053] The embodiments described above are merely illustrative 
for the broader scope of the invention and are not limitative. For 
example, any person skilled in the art will understand that the 
method according to the invention may be applied to other kinds of 
memories as well, like opto-magnetic discs, optical discs like CD, 

25 SACD, DVD and Blue-Ray and the like. 
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= 0054 j In summary, the invention relates to a method of caching 
data stored in allocation units of a memory (102), preferably a 
harddisk drive system, of which retrieval incurs a performance 
penalty. An example of this is data in a spare sector (215) , 
5 located in a spare area (210) on the harddisk platter (200) . The 
cache memory (103) is, however, a precious commodity. The need for 
memory space may be reduced by only caching data in spare sectors 
| in which data belonging to a file that is to be retrieved is 
stored. Also the impact of other kinds of causes of performance 
10 penalties may be solved in this way, like those caused by soft 
defects and fragmentation of files. 
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| ABSTRACT ; ( j )TSCLOSUF 

The i aveH-l: ' •? • • ?:-e • • bo -aA method of - % 

includes caching data stored in allocation units of a memory (102) , 
5 preferably a harddisk drive system, of which retrieval incurs a 
performance penalty. An example of this is data in a spare sector 
(215), located in a spare area (210) on the harddisk platter (200). 
The cache memory (103) is, however, a precious commodity. The need 
for memory space may be reduced by only caching data in spare 
10 | sectors in which data belonging to a file that is... to... be. retrieved 
is stored. Also the impact of other kinds of causes of performance 
penalties may be solved in this way, like those caused by soft 
defects and fragmentation of files. 

1 5 ■F-i-g«-s?-e-4: 
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